

## What is claimed is:

| 1. A processor comprising:                                                            |
|---------------------------------------------------------------------------------------|
| a replay queue to receive a plurality of instructions;                                |
| an execution unit to execute the plurality of instructions;                           |
| a scheduler coupled between the replay queue and the execution unit to                |
| speculatively schedule instructions for execution, to increment a counter for each of |
| the plurality of instructions to reflect the number of times each of the plurality of |
| instructions has been executed, and to dispatch each instruction of the plurality of  |
| instructions to the execution unit either when the counter does not exceed a          |
| maximum number of replays or, if the counter for the instruction exceeds the          |
| maximum number of replays, when the instruction is safe to execute; and               |
| a checker coupled to the execution unit to determine whether each instruction         |

er each instruction has executed successfully, and coupled to the replay queue to communicate to the replay queue each instruction that has not executed successfully.

- 2. The processor of claim 1 further comprising: an allocator/renamer coupled to the replay queue to allocate and rename those of a plurality of resources needed by the instruction.
- 3. The processor of claim 2 further comprising: a front end coupled to the allocator/renamer to provide the plurality of instructions to the allocator/renamer.
  - The processor of claim 2 further comprising: 4. a retire unit to retire the plurality of instructions, coupled to the checker to receive those of the plurality of instructions that have executed successfully, and coupled to the allocator/renamer to communicate a de-allocate signal to the allocator/renamer.
- 5. The processor of claim 4 wherein the retire unit is further coupled to the replay queue lo communicate a retire signal when one of the plurality of instructions is retired.

5

6

7

8

9

10

11

12 13

> 1 2

3

1

2 3

1

2

3

4

5

1 2

3

| 1  | 6.              | The processor of claim 1 further comprising:                                   |  |  |  |
|----|-----------------|--------------------------------------------------------------------------------|--|--|--|
| 2  |                 | at least one cache system on a die of the processor;                           |  |  |  |
| 3  |                 | a plurality of external memory devices; and                                    |  |  |  |
| 4  |                 | a memory request controller coupled to the execution unit to obtain data       |  |  |  |
| 5  | from t          | he at least one cache system and the plurality of external memory devices.     |  |  |  |
|    |                 |                                                                                |  |  |  |
| 1  | 7.              | The processor of claim 6 wherein the at least one cache system comprises       |  |  |  |
| 2  | a first         | level cache system and a second level cache system.                            |  |  |  |
|    |                 |                                                                                |  |  |  |
| 1  | 8.              | The processor of claim 6 wherein the external memory devices comprise at       |  |  |  |
| 2  | least one of a  | least one of a third level cache system, a main memory, and a disk memory.     |  |  |  |
|    |                 |                                                                                |  |  |  |
| 1  | 9.              | The processor of claim 1 further comprising:                                   |  |  |  |
| 2  |                 | a staging queue coupled between the checker and the scheduler.                 |  |  |  |
|    |                 |                                                                                |  |  |  |
| 1  | 10.             | The processor of claim 1 wherein the scheduler comprises a plurality of        |  |  |  |
| 2  | counters to m   | aintain each of the plurality of counters for each of the plurality of         |  |  |  |
| 3  | instructions.   |                                                                                |  |  |  |
|    | •               |                                                                                |  |  |  |
| 1  | 11.             | The processor of claim 1 wherein the counter is one of a plurality of          |  |  |  |
| 2  | counters such   | that each counter of the plurality of counters is paired with one of the       |  |  |  |
| 3  | plurality of in | structions.                                                                    |  |  |  |
|    |                 |                                                                                |  |  |  |
| 1  | 12.             | The processor of claim 1 wherein the checker comprises a scoreboard to         |  |  |  |
| 2  | maintain a sta  | tus of a plurality of resources.                                               |  |  |  |
|    |                 |                                                                                |  |  |  |
| 1  | 13.             | A processor comprising:                                                        |  |  |  |
| 2  |                 | a replay queue to receive a plurality of instructions;                         |  |  |  |
| 3  |                 | at least two execution units to execute the plurality of instructions;         |  |  |  |
| 4  |                 | at least two schedulers coupled between the replay queue and the execution     |  |  |  |
| 5  | units t         | o schedule instructions for execution, to increment a counter for each of the  |  |  |  |
| 6  | plurali         | ty of instructions to reflect the number of times each of the plurality of     |  |  |  |
| 7  | instruc         | ctions has been executed, and to communicate each instruction of the plurality |  |  |  |
| 8  | of inst         | ructions to the execution units when the counter does not exceed a maximum     |  |  |  |
| 9  | numbe           | er or, if the counter for the instruction exceeds the maximum number of        |  |  |  |
| 10 | replay          | s, when a data required by the instruction is available; and                   |  |  |  |

| 11 |                                                                                            | a checker coupled to the execution units to determine whether each               |  |  |  |
|----|--------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--|--|--|
| 12 | instruction has executed successfully, and coupled to the replay queue to communicate each |                                                                                  |  |  |  |
| 13 |                                                                                            | at has not executed successfully.                                                |  |  |  |
| 1  | 14.                                                                                        | The processor of claim 13 further comprising:                                    |  |  |  |
| 2  | 7                                                                                          | a plurality of memory devices coupled to the execution units such that the       |  |  |  |
| 3  | checker deter                                                                              | mines whether the instruction has executed successfully based on a plurality of  |  |  |  |
| 4  |                                                                                            | provided by the memory devices.                                                  |  |  |  |
| •  | in or matter p                                                                             |                                                                                  |  |  |  |
| 1  | 15.                                                                                        | The processor of claim 13 further comprising:                                    |  |  |  |
| 2  | 10.                                                                                        | an allocator/renamer coupled to the replay queue to allocate and rename          |  |  |  |
| 3  | those of a plu                                                                             | rality of resources needed by the plurality of instructions.                     |  |  |  |
| J  | mose of a pre                                                                              | manify or resources mostly of and pranamy or monaculous.                         |  |  |  |
| 1  | 16.                                                                                        | The processor of claim 15 further comprising:                                    |  |  |  |
| 2  |                                                                                            | a front end coupled to the allocator/renamer to provide the plurality of         |  |  |  |
| 3  | instructions to                                                                            | o the allocator/renamer.                                                         |  |  |  |
|    |                                                                                            | 1                                                                                |  |  |  |
| 1  | 17.                                                                                        | The processor of claim 15 further comprising:                                    |  |  |  |
| 2  |                                                                                            | a retire unit to retire the plurality of instructions, coupled to the checker to |  |  |  |
| 3  | receive those of the plurality of instructions that have executed successfully, and        |                                                                                  |  |  |  |
| 4  | couple                                                                                     | ed to the allocator/renamer to communicate a de-allocate signal to the           |  |  |  |
| 5  | allocator/renamer.                                                                         |                                                                                  |  |  |  |
|    |                                                                                            |                                                                                  |  |  |  |
| 1  | 18.                                                                                        | The processor of claim 17 wherein the retire unit is further coupled to the      |  |  |  |
| 2  |                                                                                            | to communicate a retire signal when one of the plurality of instructions is      |  |  |  |
| 3  | retired.                                                                                   |                                                                                  |  |  |  |
| 1  | 19.                                                                                        | A method comprising:                                                             |  |  |  |
| 2  |                                                                                            | receiving an instruction of a plurality of instructions;                         |  |  |  |
| 3  |                                                                                            | placing the instruction in a queue with other instructions of the plurality of   |  |  |  |
| 4  | instructions;                                                                              |                                                                                  |  |  |  |
| 5  |                                                                                            | speculatively re-ordering those of the plurality of instructions in a scheduler  |  |  |  |
| 6  | based on data dependencies and instruction latencies;                                      |                                                                                  |  |  |  |
| 7  | dispatching one of the plurality of instructions to an execution unit to be                |                                                                                  |  |  |  |
| 8  | executed either when a counter for the instruction does not exceed a maximum               |                                                                                  |  |  |  |
| 9  | number of replays or if the counter for the instruction exceeds the maximum                |                                                                                  |  |  |  |
| 10 | number of replays, when a required data for the instruction is available;                  |                                                                                  |  |  |  |
| 11 |                                                                                            | executing the instruction:                                                       |  |  |  |

Express Mail No.: EL634500996US

|                                       | 12 | determining whether the instruction executed successfully;                           |
|---------------------------------------|----|--------------------------------------------------------------------------------------|
|                                       | 13 | routing the instruction back to the queue if the instruction did not execute         |
|                                       | 14 | successfully; and                                                                    |
| ア                                     | 15 | retiring the instruction if the instruction executed successfully.                   |
|                                       | 1  | 20. The method of Claim 19 further comprising:                                       |
|                                       | 2  | allocating those of a plurality of system resources needed by the instruction        |
|                                       | 1  | 21. The method of Claim 20 wherein retiring comprises:                               |
|                                       | 2  | de-allocating those of the plurality of system resources used by the                 |
|                                       | 3  | instruction being retired;                                                           |
|                                       | 4  | removing the instruction and a plurality of related data from the queue.             |
|                                       | 1  | 22. The method of Claim 19 further comprising:                                       |
|                                       | 2  | naintaining a plurality of counters, one each for each of the plurality of           |
| भेजरिकत असी बखी भेजरिकत भेजरिका भित्र | 3  | instructions in the scheduler such that the counters reflect the number of times the |
|                                       | 4  | corresponding instruction has been executed.                                         |
|                                       |    |                                                                                      |
|                                       | 1  | The method of Claim 22 wherein each of the plurality of counters for the             |
| Ì                                     | 2  | instruction is paired with each of the plurality of the instructions.                |
| L                                     |    |                                                                                      |
| _<br><u>L</u>                         | 1  | p4. The method of Claim 22 wherein the plurality of counters is stored in the        |
| ]<br>:                                | 2  | scheduler.                                                                           |
| <i>}</i>                              |    | $\ell$                                                                               |